package com.blog.cmrpersonalblog.dto.article.response;

import lombok.Data;
import java.time.LocalDateTime;

/**
 * 文章标签响应DTO
 */
@Data
public class ArticleTagResponse {

    /**
     * 标签ID
     */
    private Long id;

    /**
     * 标签名称
     */
    private String name;

    /**
     * 标签颜色
     */
    private String color;

    /**
     * 标签描述
     */
    private String description;

    /**
     * 标签图标
     */
    private String icon;

    /**
     * 排序字段
     */
    private Integer sortOrder;

    /**
     * 使用次数
     */
    private Integer useCount;

    /**
     * 状态 0-禁用 1-启用
     */
    private Integer status;

    /**
     * 状态文本
     */
    private String statusText;

    /**
     * 使用频率等级
     */
    private Integer usageLevel;

    /**
     * 使用频率描述
     */
    private String usageLevelText;

    /**
     * 创建者
     */
    private String createBy;

    /**
     * 创建时间
     */
    private LocalDateTime createTime;

    /**
     * 更新者
     */
    private String updateBy;

    /**
     * 更新时间
     */
    private LocalDateTime updateTime;

    /**
     * 关联的文章数量（当前有效的文章）
     */
    private Integer articleCount;

    /**
     * 获取状态文本描述
     */
    public String getStatusText() {
        if (status == null) {
            return "未知";
        }
        switch (status) {
            case 0:
                return "禁用";
            case 1:
                return "启用";
            default:
                return "未知";
        }
    }

    /**
     * 获取使用频率等级
     * @return 0-未使用 1-低频 2-中频 3-高频
     */
    public Integer getUsageLevel() {
        if (useCount == null || useCount == 0) {
            return 0;
        } else if (useCount <= 5) {
            return 1; // 低频
        } else if (useCount <= 20) {
            return 2; // 中频
        } else {
            return 3; // 高频
        }
    }

    /**
     * 获取使用频率描述
     */
    public String getUsageLevelText() {
        switch (getUsageLevel()) {
            case 0:
                return "未使用";
            case 1:
                return "低频";
            case 2:
                return "中频";
            case 3:
                return "高频";
            default:
                return "未知";
        }
    }

    /**
     * 是否启用
     */
    public boolean isEnabled() {
        return status != null && status == 1;
    }

    /**
     * 是否被使用
     */
    public boolean isUsed() {
        return useCount != null && useCount > 0;
    }
}